/**
 * 应用入口文件
 * 负责初始化 Vue 应用、注册插件、挂载到 DOM
 */

// Vue 核心库
import { createApp } from 'vue'
// Pinia 状态管理库
import { createPinia } from 'pinia'
// Element Plus UI 组件库
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
// Element Plus 图标库
import * as ElementPlusIconsVue from '@element-plus/icons-vue'
// Element Plus 中文语言包
import zhCn from 'element-plus/es/locale/lang/zh-cn'

// 根组件
import App from './App.vue'
// 路由配置
import router from './router'
// 全局样式（包含 Tailwind CSS）
import './assets/main.css'

// 创建 Vue 应用实例
const app = createApp(App)

// 全局注册所有 Element Plus 图标组件
// 注册后可以直接在模板中使用，如：<el-icon><User /></el-icon>
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
  app.component(key, component)
}

// 注册 Pinia 状态管理
app.use(createPinia())

// 注册 Vue Router 路由
app.use(router)

// 注册 Element Plus 组件库，并配置中文语言
app.use(ElementPlus, { locale: zhCn })

// 将应用挂载到 id="app" 的 DOM 元素上
app.mount('#app')
